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DETAILED ACTION 

1 . Claims 1 , 4, 7-1 0, and 21-34 are pending. 

Papers Filed 

2. Examiner acknowledges receipt of an after-final amendment filed on 19 January 
2006. 

Finality 

1. In light of Applicant's arguments with regard to claim 4, the rejection of claim 4 
has been changed from a rejection under 35 USC 102 to 35 USC 103. Consequently, 
the finality of the Office Action mailed on 19 October 2006 has been removed and this 
Office Action is made final. 

Title 

3. The title is accepted. Objection is withdrawn. 

Claim Objections 

1 . Claim 24 is objected to because of the following informalities: Claim 24 uses the 
language, "...wherein the vector register file wherein the vector instruction...". This 
sentence does not appear to make sense grammatically. Appropriate correction is 
required. 

2. Claim 32, "the group of conditions" lacks antecedent basis. 
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Drawings 

3. Objection is withdrawn in light of Applicant's amendments. 

Claim Rejections - 35 (JSC §112 

4. Rejection has been withdrawn. 

Claim Rejections - 35 USC § 102 

5. The following is a quotation of the appropriate paragraphs of 35 
U.S.C. 102 that form the basis for the rejections under this section made in this Office 
action: 

A person shall be entitled to a patent unless - 

(b) the invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

6. Claims 1, 7-9, 21, 23 and 24 are rejected under 35 U.S.C. 102(b) as being 
anticipated by Wang et al. (U.S. Patent No. 5,187,769) hereinafter referred to as Wang. 

7. As per claim 1 , Wang discloses a microprocessor, comprising: 

a vector unit (Fig. 3 ALUs 46, 48 and 50) to execute a vector instruction to 
perform a first operation on a first set of data operands and a second operation on a 
second set of operands. The examiner asserts that the processor performs a multiply 
followed by an operand rotate right for the FMULR instruction listed in the col. 27 table. 
Both operations (multiply and rotate) operate on both sets of operands. 
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Wherein the vector instruction includes a first register field indicative of a first 
primary register in the primary register file and a first secondary register in the 
secondary register file, a second register field indicative of a second primary register in 
the primary register file and a second secondary register in the secondary register file, 
and a third register field indicative of a third primary register in the primary register file 
and a third secondary register in the secondary register file; and 

Wherein the first set of operands includes a first operand selected from the first 
primary register or the first secondary register, a second operand selected from the 
second primary register or the second secondary register, and a third operand selected 
from the third primary register or the third secondary register (Fig. 3 register files 40 and 
42, col 27 lines 22-24 and col 27 table). The examiner asserts that complex pairs of 
real and imaginary numbers are simply alternate labels for two-dimensional vector data. 
The data stored in register file 40 corresponds to an "x" vector, and constitutes a real 
portion of a number and the data stored in register file 42 corresponds to a "y" vector 
and constitutes an imaginary number. This is considered to be the "primary" and 
"secondary" register file as claimed. See col 8 lines 47-53. 

8. As per claim 7, Wang discloses the microprocessor of claim 2, wherein the vector 
unit is further characterized as being enabled to perform a cross instruction in which the 
first and second operations both use at least one operand from the primary register file 
and at least one operand from the secondary register file. (Col. 26 lines 22-45) 
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9. As per claim 8, Wang discloses the microprocessor of claim 2, wherein the vector 
unit is further characterized as being enabled to perform a cross-replicate vector 
instruction in which the first and second operations are both performed using at least 
one common operand. The examiner asserts that the FMULR operation performs a 
multiply, and then a component rotate using the same operands as the multiply. 

10. As per claim 9, Wang discloses the microprocessor of claim 2, wherein the vector 
unit is configured to store a real portion of a complex number in the primary register file 
and an imaginary portion of the complex number in the secondary register file. The 
examiner asserts that complex pairs of real and imaginary numbers are simply alternate 
labels for two-dimensional vector data. The data stored in register file 40 corresponds 
to an "x" vector, and constitutes a real portion of a number and the data stored in 
register file 42 corresponds to a "y" vector and constitutes an imaginary number 

1 . Regarding claim 21 , Wang discloses the microprocessor of claim 1 , wherein the 
second set of operands include a first operand selected from the first primary register or 
the first secondary register, a second operand selected from the second primary 
register or the second secondary register, and a third operand selected from the third 
primary register or the third secondary register (col 8 lines 53-59). 
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2. Regarding claim 23, Wang 
first and second sets of operands 
formatted operands (col 27 table- 

3. Regarding claim 24, Wang discloses the microprocessor of claim 1 , wherein 
the vector register file wherein the vector instruction includes a target register field 
indicative of a primary target register in the primary register file and a secondary 
target register in the secondary register file (fig. 14 and col 24 lines 49-51) and further 
wherein the vector unit is further configured to store a result of the first operation in the 
primary target register and to store a result of the second operation in the secondary 
target register. Examiner asserts that vector registers 40 and 42 can store the result of 
the first and second operands. 

Claim Rejections - 35 (JSC § 103 

1 1 . The following is a quotation of 35 U.S.C. 103(a) which forms the basis for 
all obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 1 02 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

12. Claims 4, 22 and 25-34 are rejected under 35 U.S.C. 103(a) as being 

unpatentable over Wang in view of Matsuo et al. (U.S. Patent No. 5,901,301) 

hereinafter referred to as Matsuo. 



discloses the microprocessor of claim 22, wherein the 
comprise first and second set of floating point 
-note "floating-point operations"). 
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1 3. As per claim 4, Wang discloses the microprocessor of claim 3, wherein the vector 
unit includes a primary floating point unit (Fig. 3 FPU 46) and a secondary floating point 
unit (Fig. 3 FPU 48), wherein the primary floating point unit is configured to perform a 
floating point operation on the first set of operands and the secondary floating point unit 
is configured to perform a floating point operation on the second set of operands. Co/. 
27 table lists instructions as "floating point operations", hence, the FPUs are configured 
to perform floating point operations. 

Wang fails to disclose 3-input execution units. 

Matsuo discloses wherein a 3-input primary floating point unit is configured to 
multiply first and third operands and further configured to add the second operand to or 
subtract the second operand from the resulting product. (Col. 27 lines 47-52) 

Matsuo discloses his invention to promote "high-speed digital signal processing" 
by taking advantage of "processing frequently used in signal processing such as a 
multiply-add operation at high speeds." (Matsuo col. 1 lines 13-16) Wang discloses 
"DSPs were developed to exploit the successive multiply/accumulate nature of signal . 
processing." (Wang col. 3 lines 24-26) Matsuo's desired outcome of higher processing 
speeds through optimizing common instructions coincides with that of Wang. 

It would have been obvious to one of ordinary skill in the art at the time of 
invention to have included Matsuo's method of adding a third operand to the product of 
first and second operands in Wang's invention for the benefit of higher speed 
processing. The combination would logically require that each of the i, j, and k portions 
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to have separate execution units (as shown in Wang fig 4) that include three inputs that 
complete a separate multiply-accumulate for each dimension. 

4. Regarding claim 22, Wang/Matsuo discloses the microprocessor of claim 4 
wherein the first operation includes multiplying two of the three first set of operands to 
obtain a first product and adding or subtracting the remaining of the first set of operands 
to or from the first product and wherein the second operation includes multiplying two of 
the three second set of operands to obtain a second product and adding or subtracting 
the remaining of the second set of operands to or from the second product (Matsuo (col 
27 lines 47-52) 

5. Regarding claim 25, Wang/Matsuo discloses a vector trait to process a vector 
instruction having an opcode and first, second, and third register fields (col 27 table), 
comprising: a register file including a primary register file having a set of primary 
registers (fig 3 reference 40) and a secondary register file having a set of secondary 
registers (fig. 3 reference 42), wherein the register field identifies a register in the 
primary register file and a corresponding register in the secondary register file (col 8 
lines 48-53— T and "j" portions); primary and secondary calculating units (fig. 4 
reference 46 and 48), wherein the primary calculating unit includes first, second, and 
third inputs to receive, respectively, first, second, and third operands of a first set of 
operands and wherein the secondary calculating unit includes fast, second, and third 
inputs to receive, respectively, first, second, and third operands of a second set of 
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operands (Matsuo Col. 27 lines 47-52) and multiplexing circuitry controlled by the 
opcode to select each of the first, second, and third operands in the first and second set 
of operands from the set of primary and secondary file registers identified by the 
register fields. Examiner asserts that multiplexing circuitry inherently exists because 
different inputs are required to enter the execution units for different calculations. 

6. Regarding claim 26, Wang/Matsuo discloses the vector unit of claim 25, wherein 
the multiplexing circuitry is controlled by the opcode to select: the first operand in the 
first set of operands from either the first primary or the first secondary registers (col 27 
table — Examiner asserts that the opcode controls the register value that enters the 
execution unit; therefore, it control the multiplexing circuitry)] the second operand in the 
first set of operands from either the second primary or the second secondary registers 
(col 8 lines 53-59); and the third operand in the first set of operands from either the third 
primary or the third secondary registers (col 8 lines 53-59); the first operand in the 
second set of operands from either the first primary or the first secondary registers, the 
second operand in the second set of operands from either the second primary or the 
second secondary registers; and the third operand in the second set of operands from 
either the third primary or the third secondary registers (col 8 lines 53-59 and col 27 
table). 

7. Regarding claim 27, Wang/Matsuo discloses the vector unit of claim 25, wherein 
the primary calculating unit is controlled by the opcode to perform a first operation on 
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the first set of operands and the secondary calculating unit is controlled by the opcode 
to perform a second operation on the second set of operands (Matsuo Col. 27 lines 47- 
52— Examiner asserts that the MAC opcode would control the execution units of both 
primary and secondary portions). 

8. Regarding claim 28, Wang/Matsuo discloses the vector unit of claim 27, wherein 
the first operation differs from the second operation. 

Examiner asserts that the operations are completed on two different sets of 
operands, therefore, the two operations differ. 

9. Regarding claim 29, Wang/Matsuo discloses the vector unit of claim 27, 
wherein the first and second operations both include multiplying their respective 
first and third operands to obtain respective first products and adding or subtracting 
their respective second operands to or from the respective first products (Matsuo Col. 
27 lines 47-52). 

10. Regarding claim 30, Wang/Matsuo discloses the vector unit of claim 25, wherein 
the first, second, and third operands of the first and second sets of operands are all 
floating point formatted operands (col 27 table). 

1 1 . Regarding claim 31 , Wang/Matsuo discloses a microprocessor including: an 
execution unit enabled to execute an asymmetric instruction, wherein the 
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asymmetric instruction includes a set of three operand register fields and a target 
register field and an operation code (opcode) (col 24 lines 49-51); a register file 
accessible by the execution unit and having a rank of two including a primary 
register file (fig 3 reference 40) and a secondary register file (fig 3 reference 42) wherein 
a value in an operand register field identifies a register in the primary register file and 
a corresponding register in the secondary register file (col 8 lines 53-59); wherein the 
execution unit is configured to perform a first operation on a first set of three 
operands (Matsuo Col. 27 lines 47-52) selected from registers identified by the set of 
operand register fields and to perform a second operation on a second set of 
three operands also selected from the registers identified by the set of operand 
registers fields (see combination) wherein the first and second operations and. 
selection of the first and second sets of operands are determined by the opcode. 

Examiner asserts that the opcode determines that the operands are of type 
multiply-accumulate. 

12. Regarding i claim 32, Wang/Matsuo discloses the microprocessor of claim 31, 
where at least one condition selected from the group of conditions consisting of the 
first and second operations being different and the first and second sets of operands 
being different is true. 

Examiner asserts that the operands are different (i.e. one includes the T 
operands and the other includes "j" operands). Consequently, the operations are 
considered to be different. 
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1 3. Regarding claim 33, Wang/Matsuo discloses the microprocessor of claim 31 , 
wherein the execution unit is further configured to store a result of the first operation 
in a register of the primary register file determined by the target register field and 
the result of the second operation in a register of the secondary register field also 
determined by the target register field (Matsuo Col. 27 lines 47-52). 

14. Regarding claim 34, Wang/Matsuo discloses he microprocessor of claim 31, 
including multiplexing circuitry controlled by the opcode to select a first of the first set 
of three operands from a first primary and a first secondary register identified by a 
first operand register field, a second of the first set of three operands from a second 
primary and a second secondary register identified by a second operand register 
field, a third of the first set of three operands from a third primary and a third 
secondary register identified by a first operand register field (col 8 lines 53-59) , a first 
of the second set of three operands from a first primary and a first secondary register 
identified by a first operand register field, a second of the second set of three operands 
from a second primary and a second secondary register identified by a second operand 
register field, and a third of the second set of three operands from a third primary and a 
third secondary register identified by a first operand register field (col 27 table). 
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14. Claim 10 is rejected under 35 U.S.C. 103(a) as being unpatentable over Wang in 
view of Golliver et al. (U.S. Publication No. US 2002/0004809) hereinafter referred to as 
Golliver. 

15. As per claim 10, Wang discloses the microprocessor of claim 9, but fails to 
disclose wherein the vector unit is configured to perform a complex operation in which 
the imaginary portion of a first operand is multiplied by an imaginary portion of a second 
operand in the first operation and in which the imaginary portion of the first operand is 
multiplied by a real portion of the second operand in the second operation. 

16. Golliver discloses a vector unit configured to perform a complex operation in 
which the imaginary portion of a first operand is multiplied by an imaginary portion of a 
second operand in the first operation (AiBi in Fig. 3A) and in which the imaginary portion 
of the first operand is multiplied by a real portion of the second operand in the second 
operation (AiBr in Fig. 3A). 

17. Golliver discloses "a data manipulation instruction for enhancing value and 
efficiency of performing complex arithmetic instructions." (Paragraph 2) Golliver' s 
desired outcome coincides with that of Wang: increased efficiency of processing. 

1 8. It would have been obvious to one of ordinary skill in the art at the time of 
invention to have included Gollivers method of complex number arithmetic in Wang's 
processor for the benefit of increased processing efficiency. 



Response to Arguments 
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have been fully considered but they are 



16. Applicant states: 

"Wang does not describe a vector execution unit for instructions having three operand registers in 
which all of the operands are provided by a rank-of-two register file" 

Examiner disagrees. Wang's register files 40 and 42, as far as is disclosed in the 
claims, anticipate the "rank-of-two" register file. 

17. Applicant states: 

"Wang does not disclose either expressly or inherently a vector processing unit that uses a two- 
wide register file" 

Examiner disagrees. Simply because Wang discloses three register files does 
not mean that Wang doesn't disclose two register files. The third register file does not 
prevent Wang from anticipating the claims as amended. 

Conclusion 

19. The prior art made of record and not relied upon is considered pertinent to 

applicant's disclosure. / 

Seshan (U.S. Patent No. 6,061 ,787) discloses a processor consisting of multiple 
parallel register files. 

Tromp et al. (U.S. Publication No. US 2005/0283592) disclose a system 
executing two operations based on a single instruction. 



Application/Control Number: 10/699,571 Page 15 

Art Unit: 2183 

Gochman et al. (U.S. Patent No. 6,920,546) disclose a system with multiple 
operations in an instruction word sharing common operands. 

18. Applicants amendment necessitated the new ground(s) of rejection presented in 
this Office action, Accordingly, THIS ACTION IS MADE FINAL. See MPEP 
§ 706.07(a). Applicant is reminded of the extension of time policy as set forth in 37 
CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
mailed until after the end of the THREE-MONTH shortened statutory period, then the 
shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1 .136(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later 
than SIX MONTHS from the date of this final action. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Brian P. Johnson whose telephone number is (571) 272- 
2678. The examiner can normally be reached on 8-4:30 M-F. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 
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Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 




